<template>
  <header>
    <slot name="header">Default Header</slot>
  </header>
  <main>
    <slot name="content" :msg="msg">Default Content</slot>
  </main>
  <footer>
    <slot name="footer">Default Footer</slot>
  </footer>
  <button @click="onClick">{{ buttonText}}</button>
</template>

<script setup lang="ts">
import {getCurrentInstance, onMounted, ref} from "vue";

defineProps(['buttonText'])

const emits = defineEmits(['logout'])

const msg = ref('Hello World')

const onClick = () => {
  emits('logout')
}

onMounted(() => {
  console.log(getCurrentInstance())
})

</script>

<style scoped>
h1 {
  font-weight: 500;
  font-size: 2.6rem;
  position: relative;
  top: -10px;
}

h3 {
  font-size: 1.2rem;
}

.greetings h1,
.greetings h3 {
  text-align: center;
}

@media (min-width: 1024px) {
  .greetings h1,
  .greetings h3 {
    text-align: left;
  }
}
</style>
